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(57) ABSTRACT 

An interactive television trigger has a time attribute value 
that indicates a future time when the trigger is to be 
executed. In many situations, the trigger is sent to the 
receiver unit prior to the future time (e.g., to account for 
bandwidth limitations or to allow prefetching of an infor- 
mation resource associated with the trigger). Redundant 
triggers may be sent as the future time draws closer. In this 
way, if the receiver unit did not receive a previously sent 
trigger for some reason, a redundant trigger is available for 
execution. The receiver unit may ignore duplicate triggers. 
The time attribute value also may indicate a life span during 
which the trigger is valid so that, if a user switches video 
channels but returns to a video channel for which execution 
of the trigger is desired, the trigger may be re-executed 
during the life span. 
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TRIGGER HAVING A TIME ATTRIBUTE 201. Accordingly, there is not adequate bandwidth left for 

the communication of the trigger 109 at time 200. 

BACKGROUND INFORMATION A conventional method of living this problem involves 

FIG. 1 (Prior Art) is a simplified diagram of an interactive sending the trigger 109 beforehand (out of synchronization) 

television system 100. System 100 includes a receiver unit 5 with respect the point in the associated broadcast television 

101, a receiving antenna 111, and a remote control unit 102, video 105 where the trigger 109 is to be executed. In the 

A viewer uses the remote control unit 102 to control the example illustrated, trigger 109 is sent via the VBI line 21 

receiver unit 101 and/or to interact with interactive televi- sub-channel at time 202 before period 201. Receiver unit 

sion content via the receiver unit 101. A video link 103 101, rather than executing trigger 109 immediately upon 

couples receiver unit 101 to an ordinary analog television set 10 receipt, executes a script on the information resource 108 to 

104 so that the receiver unit can use the screen of the which the trigger 109 is addressed. The script involves a 

television set as a display device. The receiver unit 101 delay loop that delays the execution of trigger 109 until time 

receives broadcast television video 105 on receiving antenna 200. 

Ill and displays it as television video 106 on the screen of The use of such a delay loop, however, introduces several 
the television set 104. 15 complexities. The magnitude of the delay of such a delay 
In interactive television, information 107 from an in for- loop is generally somewhat unrepeatable and difficult to 
mation resource 108 is displayed along with television video control. The magnitude of the delay may, for example, vary 
106 in a synchronized fashion. When the information 107 is from receiver unit to receiver unit due to hardware differ- 
to be displayed at a particular point in the television video, ences. The magnitude of the delay may also be affected by 
a communication called a "trigger" 109 is broadcast along 20 the particular software processes running on a receiver unit, 
with the television video 105 and is received on receiving Moreover, the coding required to realize such a delay loop 
antenna 111. Trigger 109 includes a Uniform Resource involves effort on the part of the author of the interactive 
Identifier (URI) that identifies the information resource 108. content and this is undesirable. Solutions to one or more of 
Receiver unit 101 uses this URI to retrieve the information 25 these problems are desired. 

resource 108 from the Internet 110. Receiver unit 101 then Moreover, in a current interactive television 

displays the information 107 from the information resource implementation, if trigger 109 executes in the context of a 

108 along with the television video 106 to provide an channel, and the viewer then changes channels to a different 

enhanced television viewing experience. channel, and the viewer then changes channels back, the 

Each frame of the television video 106 includes two fields 30 trigger is not reexecuted automatically. If, for example, 

of 262.5 horizontal scan lines each in accordance with the trigger 109 initially caused stock ticker tape information 107 

National Television Standards Committee (NTSC) broad- to be displayed along with video of a given channel, and if 

cast television formal standard. The first twenty-one scan the viewer switched channels and then switched back, the 

lines of each frame are commonly referred to as the "vertical stock ticker tape information 107 would not reappear 

blanking interval" (VBI lines). This interval is used to 35 because its trigger 109 would not automatically be reex- 

synchronize television receiver electronics and to return the ecuted. A solution to this problem is also desired, 
electron beam of the television to the top of the screen 
among other things. The electron beam is therefore disabled 



SUMMARY 



(i.e. "blanked") during the scan time of the first twenty-one In a first aspect of the invention, a trigger includes a time 

scan lines so that the electron beam does not scribe a visible 40 attribute indicative of a time in the future when the trigger 

line from the bottom of the screen to the top of the screen is to be executed. Providing a time in the future when the 

when it is being returned to the top of the screen. The entire trigger is to be executed allows the trigger to be sent in 

vertical blanking interval is, however, generally not required advance when there is adequate transport bandwidth to 

for vertical synchronization and vertical beam retrace. Only transport the trigger to the receiver unit. The receiver unit 

VBI lines 1-9 of a field are generally required. The other 45 receives the trigger but knows from the future time attribute 

twelve lines 10-21 of the field are therefore available for the that the trigger is not to be executed yet, but rather is to be 

communication of other information. executed at the indicated future time. The receiver unit 

VBI line 21, for example, provides a low speed commu- therefore waits until the indicated future time to execute the 

nication sub-channel. The Federal Communications Com- trigger. This future time attribute therefore eliminates the 

mission (FCC) mandates that part of this sub-channel be 50 need for the script and delay loop described above, 

reserved for closed captioning services as specified by In a second aspect of the invention, a trigger includes a 

EIA-608. Text subtitles are encoded into this VBI line 21 time attribute indicative of a particular frame when the 

sub-channel such that a television receiver that receives the trigger is to be executed. In one embodiment, each frame of 

signal can decode the information encoded into VBI line 21 video is numbered with a frame number that is embedded in 

and display it as a text subtitle along with the television 55 the video in accordance with a standard. The receiver unit 

video to assist the hearing impaired. Sparc bandwidth avail- monitors these frame numbers (or otherwise keeps track of 

able in this VBI line 21 sub-channel after the encoding of the the number of the current frame) and waits to execute the 

closed captioning information may be used to transport the trigger until the frame identified by the time attribute of the 

interactive television triggers such as trigger 109 to the trigger has been received. This future time attribute therefore 

receiver unit 101 at an appropriate time with respect to the 60 eliminates the need for the script and delay loop described 

broadcast television video 105. above. 

FIG. 2 illustrates a problem associated with the use of the In a third aspect of the invention, a receiver unit receives 

VBI line 21 sub-channel for the transport of trigger 109. a trigger with an attribute indicating that the trigger is to be 

Trigger 109 is desired to be transmitted to receiver unit 101 executed at some time in the future or some frame in the 

at lime 200 with respect to broadcast television video 105. 65 future. The receiver unit determines whether the receiver 

There is in this example, however, particularly heavy closed unit has enough time to retrieve an information resource 

captioning use of the VBI line 21 sub-channel during period identified by the trigger (this may involve establishing a 
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connection to the Internet and retrieving the information FIG. 7 is a flowchart of a method wherein a time attribute 

resource from the Internet). If the receiver unit determines value indicates a future time by identifying a future frame of 

that there is enough time, then the receiver unit pre-f etches video. 

the information resource so that it is available at the future piGS. 8 and 9 illustrate examples of triggers that have 

time or future frame when the trigger is to be executed. 5 time attribute values that identify future frames of video and 

Triggers are therefore sent well before they are to be are usa ble in the method of FIG. 7. 

executed so that receiver units will pre-fetch associated nG 10 ig a q[ a method wherem a id 

information resources. Such pre-fetching is used in some haym a ^ ^ fc transmitted weU before it is 

embodiments to have receiver units access the Internet at tQ be SQ that a receivef UQit can fetch an 

off-peak .(low i Cost) times and retrieve information resources 10 mformation resource identified b the tri before the 

needed tor subsequent interactive television viewing at peak trieeer is executed 

(high cost) times. . 

» £ , « r t • i ■ 1 i FIG. 11 is a diagram illustrating the method of FIG. 10. 

In a fourth aspect of the invention, multiple triggers to the ° ° 

same associated information resource on the Internet are all FIG - 12 Urates an embodiment of the invention 

sent indicating the same future time or future frame for is wherein a tngger has a time attribute value that indicates a 

execution so that if a receiver unit for some reason does not Ufe s P an for the ^S^ 1 "- 

receive the earlier triggers (the earlier triggers are provided FIG. 13 is a flowchart of a method in accordance with the 

to cause the receiver unit to prefetch the associated infer- embodiment of FIG. 12. 

mation resource), then the receiver unit will at least receive FIG. 14 illustrates an example of a time attribute value 

the last trigger and be able to execute it (this will generally 20 that indicates a life span of the trigger of FIG. 12. 

require prompt retrieval of the associated information FIG. 15 is a diagram of a time attribute value that 

resource from the Internet). indicates a life span of a trigger where the life span starts 

In a fifth aspect of the invention, a trigger has a time when the trigger is received, 

attribute which provides a time up until which the trigger is FIG. 16 is a simplified diagram illustrating the life span 

valid for presentation (i.e., a "life span" for the trigger). 25 specified by the time attribute value of FIG. 15. 

Providing the fife span time attribute allows a trigger to be FIGS 17> 18? 19 and 20 illustrate other examples of time 

executed in the context of a channel, allows the viewer to attribute values that indicate life spans, 
change channels and then change back, and allows the 

receiver unit automatically to reexecute the trigger if it is DETAILED DESCRIPTION 

still valid (has not expired). 3 ^ a flowchart of a method in accordance with one 

Future times of tngger execution, life span starting times embodiment wherein a trigger (for example, trigger 400 in 

and/or life span ending times can be expressed using mul- FIG. 4) has a time attribute value. The time attribute value 

tiple different characters and codes. Such times can be ^ indicative 0 f a future time. In a first step (step 300), the 

designated as absolute times and/or as relative times. Such trigger having the time attribute ^ received on a receiver 

times can be designated in terms of wall-clock time and/or unit In one embodiment, the receiver unit is a WebTV® 

media time base time. A receiver unit need not receive media xUtop Intemet Terminal ^ described in the following 

encoded with time stamps in order to support media time documen ts: U.S. patent application Sen No. 09/099,118, 

base time attribute values, rather the receiver unit can keep entitled "Communicating Logic Addresses Of Resources In 

track of the media time base by monitoring the progress of A Data Service Channel Of A Video Signal", filed Jun. 17, 

the media (for example, by maintaining a count of succes- 1998) by Danie i j. zigmond, et ah; U.S. patent application 

sive frames of video media as successive frames of the video Ser No 0 9/295,746, entitled "Enabling And/Or Disabling 

media are received). Selected Types Of Broadcast Triggers", filed Apr. 20, 1999, 

Triggers with time attributes can synchronize events with by Park, et al.; and U.S. patent application Ser. No. 09/295, 

respect to information other than video. Triggers with time 45 436, entitled "Receiving An Information Resource From 

attributes can, for example, synchronize events with respect The Internet If It Is Not Received From A Broadcast 

to audio. Such triggers can, for example, be transmitted via Channel", filed Apr. 20, 1999, by Zigmond, et al. (the 

radio transmission along with audio information so as to content of these documents is incorporated herein by 

synchronize events with respect to the audio as it is received reference). The receiver unit may involve a television and 

by radio receiver units and/or to cause retrieval of informa- 5Q Internet Terminal that are integrated together to constitute a 

tion or prefetching of information by radio receiver units. single device. The receiver unit may also involve another 

Other aspects of the invention and other embodiments are type of receiver unit including a personal computer having 

described in the detailed description below. This summary a television tuner card such as the "Windows® 98 Broadcast 

does not purport to define the invention. The invention is PC" system. In some embodiments, the receiver unit 

defined by the claims. 55 includes a cable modem that couples the receiver unit to a 

BRIEF DESCRIPTION OF THE DRAWINGS Cab ' 6 (for 6Xample ' 3 COaxial Cable 0r a flber ° plic Cable) - 

The receiver unit determines the future time from the time 

FIG, 1 (Prior Art) is a simplified diagram of an interactive attribute and waits (step 301) until the indicated future time, 

television system 100. At me indicated future time, the receiver unit executes the 

FIG. 2 (Prior Art) illustrates a problem that may be 60 trigger. Because the receiver unit determines the future time 

encountered when transmitting triggers to interactive tele- from the time attribute, the delay loops used to delay the 

vision system 100, execution of triggers described above are not needed. 

FIG. 3 is a flowchart of a method wherein a trigger has a FIG. 4 is a diagram of an example of a trigger 400 usable 

time attribute value. in the method of FIG. 3. Trigger 400 includes a Uniform 

FIGS. 4, 5 and 6 illustrate diagrams of examples of 65 Resource Identifier (URI) 401, a script 402, a time attribute 

triggers that have time attribute values and that are usable in value 403 indicative of the future time, a version number 

the method of FIG. 3. 404 and a checksum 405. The general format of trigger 400 
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and methods of transporting trigger 400 to the receiver unit based time. In this example, time attribute value 603 does 

are set forth in: 1) Electronic Industries Association standard not contain a "PP" to designate a fraction of the second. 

EIA-746A, and 2) Advanced Television Enhancement fiq. 7 is a flowchart of a method in accordance with 

Forum Specification (ATVEF) Draft Version 1.1, revision 26 another embodiment wherein the future time indicated by 

(the subject matter of these two documents is incorporated 5 me time attribute value of the trigger is indicated in terms of 

herein by reference). a me dia time base. In a first step (step 700), a trigger (for 

The general format of dates in trigger 400 is set forth in example, trigger 800 of FIG. 8) having a time attribute value 

International Organization for Standardization standard is received on a receiver unit. The time attribute value 

ISO -8 601 (the subject matter of which is incorporated herein indicates of a future frame of video, 

by reference). The YYYY digits of the time attribute value 10 Rathef than immediately executing the trigger, the 

403 indicate the year of the future time; the MM digits receiver unit waits (step 701) until the future frame indicated 

indicate the month; and the DD digits indicate the day. The by tne time attribute value has been received. When the 

"T" in the time attribute value 403 after the date indicates fu lure frame is received on the receiver unit, then the 

that the value 403 indicates a wall-clock date and time (as receiver unit executes the trigger (step 702). 

opposed to a media time base time) The HH digits in the is FIG . 8 ^ a diagramofone example ofa lrigger800 usable 

time attribute value 403 indicate the hour of the future time; in the method of FIG ? Tri 800 indudes a URI 801 a 

the MM digits indicate the month; the SS digits indicate the name aUribute g02j a ^ aUribme value 8Q3 a yersion 

second; and the PP digits indicate the fraction of the second. number 804 and a checksum 805 . Each frame of video in this 

The precision of fractional seconds is arbitrary In this e ^ fa encoded with a ffame number such mat each 

example, each second is broken into sixty parts. The values 20 succefisive individual frame of video ^ lhin a second has a 

for PP in this example therefore range from 00 to 59. frame number one integer larger than the previous frame 

The receiver unit maintains an indication of the current There are about thirty frames of video each second in an 

date and time (i.e., the current wall-clock time). The receiver National Television Standards Committee (NTSC) video 

unit may, for example, involve a real-time clock in either signal NTSC video frames are therefore numbered succes- 

software or hardware that maintains the current date and 25 sively from 00 to 29 each second in accordance with the 

time. In addition, or in the alternative, the current date and Society of Motion Picture and Television Engineers 

time can be periodically broadcasted to the receiver unit via (SMPTE) 12M standard. The "C" in the time attribute 803 

a suitable mechanism. There are, for example, mechanisms indicates that the value "HH:MM:SS:FF" indicates a future 

for broadcasting time on XDS in analog television and there time in terms of a media time base (in this case, time 

are other mechanisms for broadcasting time in digital tele- attribute 803 identifies a particular frame) rather than in 

vision. These mechanisms can be used to communicate the terms of wall-clock time. The "HH" digits indicate the hour 

current date and time to the receiver unit. 0 f the frame; the "MM" digits indicate the minute of the 

When the current wall -clock date and time as maintained frame; the "SS" digits indicate the second of the frame; and 

by the receiver unit matches the future date and time 35 the "FF" digits indicate the number of the frame within the 

indicated by the time attribute value 403, then the receiver second. If the character 806 is a colon as it is in this example, 

unit executes the trigger 400. In the illustrated example, then the time attribute value 803 is a drop frame code, 

execution of the trigger involves execution of script whereas if character 806 is a semi-colon, then the time 

"BOOM( )". Version number 404 indicates an ATVEF attribute value 803 is a non-drop frame code, 

trigger standard version number with which trigger 400 4Q The time attribute value 803 in the example of FIG. 8 

comports. indicates the future time by referencing the frame number of 

FIG. 5 is a diagram of another example of a trigger 500 a particular frame of video that will be received in the future, 

usable in the method of FIG. 3. Trigger 500 includes a URI Generally the frames of a segment of video are numbered 

501, a name attribute value 502, a time attribute value 503, starting at "00:00:00:00". The receiver unit monitors the 

a version number 504 and a checksum 505. The "T" 45 numbers of successively received video frames. When the 

indicates that the time attribute value 503 indicates a time in receiver unit receives the frame indicated by the time 

terms of wall-clock time as opposed to a time in terms of a attribute value 803, then the receiver unit executes the 

media time base such. as a number of frames. In the exam pie trigger 800. In the illustrated example, the name attribute 

of FIG. 5, there is no date before the "T" so value 503 802 causes the name OSCAR to be displayed on the receiver 

indicates the next occurrence of the time. The "+" in the time 50 unit. Version number 804 indicates an ATVEF trigger stan- 

attribute value 503 means that the value 503 indicates a dard version number with which trigger 800 comports, 

relative time (a relative time between the current wall-clock FIG. 9 is a diagram of another example of a trigger 900 

time and the future time when the trigger is to execute). usable in the method of FIG. 7. Trigger 900 is similar to 

Trigger 500 is therefore to be executed an "HH:MM:SS.PP" trigger 800 of FIG. 8 in that the time attribute value identifies 

amount of time after the time when the trigger was received 55 a future time in terms of media time base time as opposed 

(i.e., from the current wall-clock time when the trigger was to wall-clock time. Trigger 900 has a "+" indicating that the 

received). The receiver unit determines the passage of value of the time attribute is a relative value. Accordingly, 

"HH:MM:SS.PP" using wall-clock time rather than using a trigger 900 is to be executed "HH:MM:SS:FF" frames from 

media time base. At the future time, the name attribute 502 the current frame (the frame when trigger 900 was received 

causes the name "OSCAR" to be displayed to the viewer. 60 on the receiver unit). 

FIG. 6 is a diagram of another example of a trigger 600 FIG. 10 is a flowchart of a method in accordance with 

usable in the method of FIG. 2. Trigger 600 has a URI 601, another embodiment. FIG. 11 is a diagram illustrating the 

a script 602, a time attribute 603, a version number 604, and method of FIG. 10. In this embodiment, a trigger 1100 that 

a checksum 605. The time attribute does not, however, is to execute at a future time 1101 is sent early so that the 

contain a date. Trigger 600 executes on the next occurrence 65 receiver unit prefetches an information resource identified in 

of time "HH:MM:SS". The "T" indicates that the time the trigger. In a first step (step 1000), the trigger 1100 having 

"HH:MM:SS" is a wall-clock time as opposed to a media a time attribute value is received on a receiver unit. The time 
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attribute value indicates the future time 1101 when the received. Executing the second trigger 1105 would not 

trigger 1100 is to be executed. The trigger 1100 also iden- provide for the prefetching of the information resource as 

tifies an information resource that should be available on the would have been the case were first trigger 1100 received, 

receiver unit when the trigger is executed. An example of but the receiver unit would still be able to retrieve the 

such an information resources is web page content that is to 5 information resource at time 1101. 

be displayed on the receiver unit along with television video The receiver unit can distinguish first triggers from see- 
when the trigger is executed, ond triggers in one of many suitable ways. In one 
Next (step 1001), if there is enough time before future embodiment, a trigger is determined to be a second trigger 
time 1101 for the receiver unit to retrieve the information if its URI is the same as the URI of an earlier received trigger 
resource from a remote information store (for example, from 10 that will be executed at a future time. If the receiver unit has 
a server on the Internet), then the receiver unit retrieves (i.e. already received a first trigger and then receives such a 
prefetches) the information resource from the remote infor- second trigger that has the same URI and identifies the same 
mation store. This prefetching occurs in FIG. 11 during time information resource, then the receiver unit may ignore the 
period 1102. Trigger 1100 in some embodiments has a URI second trigger. 

that identifies the information resource on the Internet. 15 FIG. 12 is a diagram that illustrates another embodiment 

Once the information resource has been retrieved from the in accordance with the invention. This embodiment involves 

remote information store, then trigger 1100 is executed (step a trigger that indicates a life span 1201 for the trigger. FIG. 

1002) at future time 1101 indicated by the time attribute 13 is a flowchart illustrating a method in accordance with 

value of trigger 1100. In this way, receipt of trigger 1100 by this embodiment. Initially (step 1300), video from a first 

the receiver unit causes the receiver unit to prefetch the 20 broadcast channel is received and displayed on a receiver 

information resource needed to execute the trigger so that unit. Next (step 1301), a trigger 1200 having a time attribute 

the information resource is present on the receiver unit at value indicating a life span 1201 is received by the receiver 

future time 1101 when trigger 1100 is executed. This unit. In FIG. 12, time progresses from left to right in the 

prefetching avoids the need to retrieve the information direction of the horizontally extending arrow labeled TIME, 

resource at the future time. 25 The vertically pointing arrow 1200 indicates the point in 

A time attribute value can be used to facilitate the time on tne arrow labeled when the tri Sg er 1200 is 

prefetching of information by a relay station (such as a received. In one embodiment, trigger 1200 is encoded into 

satellite uplink station) for subsequent insertion of the VBI line 21 of a first channel of an NTSC broadcast signal, 

information into a signal being relayed by the relay station Tri Sg er 1200 can > however, be communicated to the receiver 

to receiver units. In some embodiments, only a selected type umt via other transport mechanisms, 

of information (for example, disconnected content) is FIG, 14 illustrates one possible time attribute value 1400 

prefetched and inserted as set forth in U.S. patent application of trigger 1200, The "/" 1401 indicates that the time attribute 

Ser. No. 09/345,247, entitled "Interactive Television Trig- value indicates a life span. The time value 1402 preceding 

gers Having Connected Content/Disconnected Content 35 the "/" indicates the starting time 1202 of the life span. The 

Attribute", filed Jun. 30, 1999, by Leak, et al. (the subject time value 1403 following the "/" indicates the ending time 

matter of which is incorporated herein by reference). A 1203 of the life span. The "Ts" in these values 1402 and 

trigger filter such as described in U.S. patent application Ser. 1403 indicate that these times are wall-clock times (as 

No. 09/295,746, entitled "Enabling And/Or Disabling opposed to media time base times). The receiver unit does 

Selected Types Of Broadcast Triggers", filed Apr. 20, 1999, 4Q not immediately execute trigger 1200 because the current 

by Park, et al. can be employed to distinguish the selected time is not within the life span 1201 indicated by time 

type of trigger from other types of triggers (the subject attribute value of trigger 1200. 

matter of this application is incorporated herein by Next (step 1302), at time 1202, the receiver unit deter- 

reference). mines that the current time is within the life span 1201 of 

FIG. 11 also illustrates another embodiment in accordance 45 trigger 1200. The trigger can be executed within life span 

with the present invention. Broadcasting trigger 1100 1201. In one embodiment, the receiver unit automatically 

(hereinafter referred to as the first trigger) well before the executes trigger 1200 without further human input upon 

future time 1101 when it is to be executed allows the reaching time 1202. Execution of trigger 1200 is illustrated 

prefetching of the associated information resource during m PIG* 12 by arrow 1204. 

time period 1102 as described above. If only first trigger 50 In one embodiment, execution of trigger 1200 causes an 

1100 were broadcast, however, then a receiver unit that was icon to be displayed on the receiver unit. If a viewer selects 

not receiving triggers during time period 1103 (for example, the icon using a remote control unit of the receiver unit, then 

a receiver unit that was turned off during time period 1103 an enhancement is displayed on the receiver unit along with 

and was turned on at time 1104) would not receive the first video from the first broadcast channel. Execution of trigger 

trigger 1100. A viewer could be watching interactive tele- 55 1200 may, for example, entail retrieving an information 

vision on the receiver unit after time 1104, but the enhance- resource identified by trigger 1200 from the Internet and 

ment that should have been provided by executing trigger displaying that information resource on the receiver unit. 

1100 would not be available as it should because trigger Next (step 1303), the channel of video being displayed by 

1100 would not have been received. the receiver unit is switched from the first channel to a 

In accordance with one embodiment of the invention, a 60 second channel. When the channel of video is switched to 

second trigger 1105 for the same enhancement as first trigger the second channel, the enhancement is no longer displayed 

1100 is broadcast slightly before or at future time 1101. because the trigger 1200 is not associated with the second 

Accordingly, if a receiver unit does not receive first trigger channel. The switching of channels from the first channel to 

1100 because it was not receiving triggers up until time the second channel is illustrated in FIG. 12 as occurring at 

1104, the receiver unit would nevertheless receive the sec- 65 time 1205. 

ond trigger 1105. Second trigger 1105 would then be After a period of time, the channel of video is switched 

executed despite the fact that first trigger 1100 was not back (step 1304) to first channel at time 1206 so that video 
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from the first channel is again displayed on the receiver unit. 
Such a switching of channels from the first channel to the 
second channel and back to the first channel may be due to 
a viewer's perusing various channels. 

If the time 1206 when the channel of video being dis- 
played is switched back to the first channel is within life 
span 1201 of trigger 1200, then the trigger is valid for 
execution. In one embodiment, trigger 1200 is automatically 
reexecuted (step 1305) by the receiver unit so that the 
enhancement is displayed on the receiver unit along with the 
first channel video. In this way, a viewer can be viewing a 
first channel of video along with a particular enhancement, 
switch channels to another channel, and then return to the 
first channel of video, such that the enhancement previously 
being viewed will be automatically displayed if the current 
time is still within the life span 1201 of the trigger. 

There are many ways that a time attribute value can 
indicate a life span. FIG. 15 illustrates a time attribute value 
1500 that indicates a life span that starts when the receiver 
unit receives the trigger and ends at an absolute time (not a 
relative time). FIG. 16 is a diagram illustrating the life span 
1601 indicated by the time attribute value 1500 of FIG. 15. 
In the example of FIG. 15, the absence of a value preceding 
the "f character 1501 in the time attribute value 1500 
indicates that the life span 1601 starts at the time 1602 when 
trigger 1600 is received, life span 1601 ends at time 1603 
indicated by the value 1502 that follows the "/" character 
1501. Time value 1502 contains a "C" indicating that life 
span ending time 1603 is expressed in terms of a media time 
base (as opposed to wall-clock time). In one embodiment, 
each frame of the broadcast video is labeled with a frame 
number and the receiver unit monitors these frame numbers 
to determine when the frame designated by the time attribute 
value is received. In another embodiment, frames of the 
broadcast video are not labeled with frame numbers. Rather, 
the receiver unit keeps track of the current frame number by 
counting the passing of each successive frame as frames are 
received. 

Rather than life span ending time 1603 being expressed in 
terms of a media time base as in the example of FIG. 15, life 
span ending time 1603 can be expressed in terms of a 
wall -clock time. In such a case, the "C in the example of 
FIG. 15 is replaced with a "T". Time attribute value 1500 
would then indicate a life span that starts when the receiver 
unit receives the trigger and that ends at a given wall-clock 
time. 

FIG. 17 illustrates another time attribute value 1700 that 
indicates a life span. The absence of a time value preceding 
the "/" character indicates that the life span starts when the 
trigger is received. The "+P" characters of time value 1701 
mean that time value 1701 indicates a duration of time. The 
"C" in time value 1701 indicates that the duration is 
expressed in terms of a media time base (as opposed to 
wall -clock time). Time attribute value 1700 therefore indi- 
cates a life span of one minute of video, wherein the minute 
is measured in terms of the media time base, and wherein the 
life span starts at the time the trigger is received. 

FIG. 18 illustrates a time attribute value 1800 that is 
similar to time attribute value 1700, except that the time 
value that indicates the duration of the life span does so in 
terms of an amount of wall -clock time (as opposed to an 
amount of time measured in the media time base). Time 
attribute value 1800 therefore indicates a life span of one 
minute of video, wherein the minute is measured in terms of 65 
wall-clock time, and wherein the life span starts at the time 
the trigger is received. 
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FIG. 19 illustrates a time attribute value 1900 that indi- 
cates a life span wherein the starting and ending times are 
expressed in terms of relative times. Both relative times are 
measured from the time of the trigger is received. Time 
value 1901 indicates that the life span starts at a time one 
minute of media from when the trigger is received. Time 
value 1902 indicates that the life span ends at a time two 
minutes from the time when the trigger is received. The one 
minute of media is measured in terms of a media time base 
as indicated by the "C" in time value 1901. The two minutes 
of media is measured in terms of a media time base as 
indicated by the "C" in ending value 1902. 

FIG. 20 illustrates a time attribute value 2000 that is 
similar to time attribute value 1900 except that the ending 
time value 2002 does not include the "+" character. The 
ending time value 2002 is therefore not relative to the time 
the trigger is received, but rather represents an amount of 
time relative to the starting time value 2001. The life span 
therefore starts at a time one minute of media from the time 
the trigger is received and extends from that time for a 
period of three minutes of media. Both the starting time and 
the three minutes of media are measured in terms of a media 
time base (as opposed to wall-clock time). 

In accordance with one embodiment, a television program 
is tape-delayed or rebroadcast at a time when its triggers are 
no longer valid (i.e., expired). To prevent these invalid 
triggers from causing receiver unit failures or otherwise 
degrading the viewing of the television show at the time of 
the tape-delay or rebroadcast, the triggers of the television 
program include life span time attributes. The ending times 
of the life span attributes of these triggers are all before the 
time of the tape-delay or rebroadcast. Because the life spans 
of these triggers have all expired at the time of the tape-delay 
or rebroadcast, the receiver unit ignores these triggers that 
are no longer valid. 

Although the present invention is described in connection 
with certain specific embodiments for instructional 
purposes, the present invention is not limited thereto. Time 
attribute values can employ characters and codes other than 
the specific characters and codes in the specific time 
attribute described above. The specific characters and codes 
used in the specific time attribute values described above are 
but one possible set of characters and codes. Other charac- 
ters and codes may be employed. The various ones of the 
characters and codes used in the specific time attributes 
described above can be used together in various combina- 
tions to designate future times of trigger execution, life span 
starting times, and/or life span ending times. Such times can 
be designated in terms of wall-clock time and/or media time 
base time. Such times can be designated as absolute times 
and/or as relative times. Time zone information and different 
precision of times may be expressed in accordance with 
International Organization for Standardization standard 
ISO-8601 (the subject matter of which is incorporated herein 
by reference). Although the specific examples of time 
attributes described above all involve an attribute of the 
form [TIME:], the time attribute can have another forms in 
accordance with the invention. The time attribute need not 
be an attribute in accordance with EI A-746A. Application of 
triggers having time attribute values are not limited to the 
video context, but rather apply more broadly to triggers in 
general including the use of triggers in radio (both analog 
radio and digital radio). The triggers that do not synchronize 
events to either video or audio may nonetheless employ a 
time attribute in accordance with the present invention. A 
receiver unit need not receive media encoded with time 
stamps in order to support media time base time attribute 
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values, rather a receiver unit can, for example, keep track of 
the media time base by monitoring the progress of the media 
(for example, by maintaining a count of successive frames 
of media as successive frames are received). Triggers having 
time attribute values can be communicated to receiver units 5 
by transports other than the VBI line 21 sub-channel. 
Broadcast television formats other than the NTSC format 
can be employed including: the Phase Alternate Lines (PAL) 
format, the Sequential Couleur Avec Me moire (SECAM) 
format, and the High Definition Television (HDTV) or 1Q 
digital television format. Triggers having time attribute 
values are not limited in application to solving bandwidth 
problems or to solving problems associated with having to 
retrieve information resources prior to trigger execution, but 
rather apply to the timing of execution of triggers in general. 

Triggers having time attributes are not limited in appli- 
cation to situations where the triggers are received onto a 
receiver unit via a broadcast transmission, but rather apply 
to any situation where triggers are used including situations 
where video stored on a storage medium (for example, on an 
optical disc) is replayed and displayed on the receiver unit. 
In such a situation, the receiver unit is considered to be 
"receiving" the triggers and the video as the triggers and 
video are received onto the receiver unit from the storage 
medium. A panel is used, rather than an icon, to present 
possible interactivity to the user in some embodiments. 
Software that carries out steps of methods in accordance 
with the present invention can be stored on any computer- 
readable medium. Examples of computer-readable mediums 
include magnetic and optical storage media and semicon- 
ductor memory. Accordingly, various modifications, 
adaptations, and combinations of various features of the 
described embodiments can be practiced without departing 
from the scope of the invention as set forth in the claims. 

What is claimed is: 

35 

1. In a computer network, which includes a plurality of 
servers and a plurality of interactive television receiver 
units, wherein the receiver units permit television sets to 
display content stored at the plurality of servers, and wherein 
the receiver units receive one or more triggers specifically 
designed for providing interactive content, a method of 
reliably and accurately executing a trigger at a desired time, 
the method comprising steps for: 

receiving at least one trigger which includes (i) a time 
attribute that indicates a future time and that is inde- 
pendent of user control, and (ii) an identifier for an 
information resource; 

determining, based on the time attribute when the at least 
one trigger should be executed; 

prefetching the information resource while waiting for the 50 
future time to arrive; and 

executing the trigger at the time indicated by the time 
attribute. 

2. A method as recited in claim 1, further comprising a 
step for receiving one or more communication channels 55 
from a broadcaster, the one or more communication chan- 
nels containing (i) broadcast content, and (ii) the at least one 
trigger. 

3. A method as recited in claim 2, wherein the prefetching 
occurs during off-peak times. 60 

4. A method as recited in claim 1, wherein the time 
attribute further indicates a life span for the at least one 
trigger, and wherein the at least one trigger corresponds to 
a first broadcast communication channel containing broad- 
cast content, the method further comprising steps for: 65 

after executing the at least one trigger, switching channels 
from the first broadcast communication channel to a 



40 



45 



second broadcast communication channel, wherein the 
at least one trigger is not valid for execution in the 
context of the second broadcast communication chan- 
nel; 

during the life span of the at least one trigger, switching 
channels back from the second broadcast communica- 
tion channel to the first broadcast communication chan- 
nel; and 

re-executing the at least one trigger. 

5. A method as recited in claim 1, wherein the future time 
comprises a relative time indicating a period of time to wait 
prior to executing the at least one trigger. 

6. A method as recited in claim 1, wherein the time 
attribute comprises a media-based time, the method further 
comprising a step for monitoring media received over the at 
least one broadcast communication channel to determine 
when the future time arrives. 

7. A computer program product for use in a computer 
network, which includes a plurality of servers and a plurality 
of interactive television receiver units, wherein the receiver 
units permit television sets to display content stored at the 
plurality of servers, and wherein the receiver units receive 
one or more triggers specifically designed for providing 
interactive content, the computer program product compris- 
ing a computer readable medium carrying computer execut- 
able instructions that implement a method of reliably and 
accurately executing a trigger at a desired time, the method 
comprising steps for: 

receiving at least one trigger which includes (i) a time 
attribute that indicates a future time and that is inde- 
pendent of user control, and (ii) an identifier for an 
information resource; 

determining, based on the time attribute when the at least 
one trigger should be executed; 

prefetching the information resource while waiting for the 
future time to arrive; and 

executing the trigger at the time indicated by the time 
attribute. 

8. A computer program product as recited in claim 7, the 
method further comprising a step for receiving one or more 
communication channels from a broadcaster, the one or 
more communication channels containing (i) broadcast 
content, and (ii) the at least one trigger. 

9. A computer program product as recited in claim 8, 
wherein the prefetching occurs during off-peak times. 

10. A computer program product as recited in claim 7, 
wherein the time attribute further indicates a life span for the 
at least one trigger, and wherein the at least one trigger 
corresponds to a first broadcast communication channel 
containing broadcast content, the method further comprising 
steps for: 

after executing the at least one trigger, switching channels 
from the first broadcast communication channel to a 
second broadcast communication channel, wherein the 
at least one trigger is not valid for execution in the 
context of the second broadcast communication chan- 
nel; 

during the life span of the at least one trigger, switching 
channels back from the second broadcast communica- 
tion channel to the first broadcast communication chan- 
nel; and 

re-executing the at least one trigger. 

11. A computer program product as recited in claim 7, 
wherein the future time comprises a relative time indicating 
a period of time to wait prior to executing the at least one 
trigger. 
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12. A computer program product as recited in claim 7, 
wherein the time attribute comprises a media -based time, the 
method further comprising a step for monitoring media 
received over the at least one broadcast communication 
channel to determine when the future time arrives. 5 

13. In a computer network, which includes a plurality of 
servers and a plurality of interactive television receiver 
units, wherein the receiver units permit television sets to 
display content stored at the plurality of servers, and wherein 
the receiver units receive one or more triggers specifically 10 
designed for providing interactive content, a method of 
reliably and accurately executing a trigger at a desired time, 
the method comprising acts of: 

for at least one trigger that comprises (i) a time attribute 
indicating a future time and independent of user 15 
control, and (ii) an identifier for an information 
resource, evaluating the time attribute to determine 
when the at least one trigger should be executed; 

retrieving the information resource prior to the future 
time; and 20 

executing the at least one trigger at the time indicated by 
the time attribute. 

14. A method as recited in claim 13, further comprising an 
act of tuning to one or more communication channels from 25 
a broadcaster, the one or more communication channels 
containing (i) broadcast content, and (ii) the at least one 
trigger, 

15. A method as recited in claim 14, wherein the retrieving 
occurs during off-peak times. 3Q 

16. A method as recited in claim 13, wherein the time 
attribute indicates a life span for the at least one trigger, and 
wherein the at least one trigger corresponds to a first 
broadcast communication channel containing broadcast 
content, the method further comprising acts of: 35 

after executing the at least one trigger while tuned to the 
first broadcast communication channel, tuning to a 
second broadcast communication channel, wherein the 
at least one trigger is not valid for execution in the 
context of the second broadcast communication chan- 4 q 
nel; 

during the life span of the at least one trigger, tuning back 

to the first broadcast communication channel; and 
re -executing the at least one trigger. 

17. A method as recited in claim 13, wherein the future 45 
time comprises a relative time indicating a period of time to 
wait prior to executing the at least one trigger. 

18. A method as recited in claim 13, wherein the time 
attribute comprises a media-based time, the method further 
comprising an act of examining the frame numbers within 50 
the broadcast content if the broadcast content includes frame 
numbers, and otherwise, counting successive frames of the 
broadcast content as the frames are received. 
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19. A computer program product for use in a computer 
network, which includes a plurality of servers and a plurality 
of interactive television receiver units, wherein the receiver 
units permit television sets to display content stored at the 
plurality of servers, and wherein the receiver units receive 
one or more triggers specifically designed for providing 
interactive content, the computer program product carrying 
computer executable instructions that implement a method 
of reliably and accurately executing a trigger at a desired 
time, the method comprising acts of: 

for at least one trigger that comprises (i) a time attribute 
indicating a future time and independent of user 
control, and (ii) an identifier for an information 
resource, evaluating the time attribute to determine 
when the at least one trigger should be executed; 

retrieving the information resource prior to the future 
time; and 

executing the at least one trigger at the time indicated by 
the time attribute. 

20. A computer program product as recited in claim 19, 
the method farther comprising an act of tuning to one or 
more communication channels from a broadcaster, the one 
or more communication channels containing (i) broadcast 
content, and (ii) the at least one trigger. 

21. A computer program product as recited in claim 20, 
wherein the retrieving occurs during off-peak times. 

22. A computer program product as recited in claim 19, 
wherein the time attribute indicates a life span for the at least 
one trigger, and wherein the at least one trigger corresponds 
to a first broadcast communication channel containing 
broadcast content, the method further comprising acts of: 

after executing the at least one trigger while tuned to the 
first broadcast communication channel, tuning to a 
second broadcast communication channel, wherein the 
at least one trigger is not valid for execution in the 
context of the second broadcast communication chan- 
nel; 

during the life span of the at least one trigger, tuning back 

to the first broadcast communication channel; and 
re-executing the at least one trigger. 

23. A computer program product as recited in claim 19, 
wherein the future time comprises a relative time indicating 
a period of time to wait prior to executing the at least one 
trigger. 

24. A computer program product as recited in claim 19, 
wherein the time attribute comprises a media-based time, the 
method further comprising an act of examining the frame 
numbers within the broadcast content if the broadcast con- 
tent includes frame numbers, and otherwise, counting suc- 
cessive frames of the broadcast content as the frames are 
received. 

***** 
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DERWENT; 
IBMJTDB 


2004/03/18 19:03 


4 


106 


/70C/CH hoc oc h on ——i— "7aa/oho ooa _ . _ . i _ 7H7/<(Oc h oo m^Im 

(725/51, 135-136, 139.CCIS. 709/21 8-220. CClS. 71 7/125-1 zo.CClS. 
71 5/500.1. eels. 707/9-1 0.ccls.) and (trigger$1 with (connect$3 or 
disconnect$3)) 


UoPAT; 
US-PGPUB; 
EPO; JPO; 
DERWENT; 
IBMJTDB 


^r\r\A /no IAQ Af\.f\~7 

2004/03/18 19:07 


6 


897 


trigger and (CATV or satellite) and (TV or teleivision) and 
interactive 


UorAI , 
US-PGPUB; 
EPO; JPO; 
DERWENT; 
IBMJTDB 


OAAyl /AO MQ *fA.AC 

2004/U3/18 ly.Uo 


7 


315 


(trigger and (CATV or satellite) and (TV or teleivision) and 
interactive) and 725/$.ccls. 


1 ICDAT. 

UoPAT; 
US-PGPUB; 
EPO; JPO; 
DERWENT; 
IBMJTDB 


OAA/1 /AO IA O 4A.AC 

2004/03/18 19.05 


5 


1 


((725/51, 135-136, 139.ccls. 709/21 8-220. eels. 717/125-128.ccls. 
71 5/500. Iccls. 707/9-1 0.ccls.) and (trigger$1 with (connect$3 or 
disconnect$3))) and (CATV or satellite) and (TV or teleivision) 
and interactive 


1 1 0 O AT. 

USPAT; 
US-PGPUB; 
EPO; JPO; 
DERWENT; 
IBMJTDB 


OAA>l/AOMO A A.A"7 

2004/03/18 19.07 


8 


87 


catv and (trigger$1 with (connects 3 or disco nnect$3)) 


i ion AT. 

USPAT; 
US-PGPUB; 
EPO; JPO; 
DERWENT; 
IBMJTDB 


OAAvl/AOMO A A.A~7 

2004/03/18 19:07 


A 

y 


A A~f 


(CATV or satellite) and (TV or television) and interactive and 
(trigger$1 with (connect$3 or disconnect$3)) 


I ICDAT- 

UorA 1 , 

US-PGPUB; 
EPO; JPO; 
DERWENT; 
IBM TDB 


onn/i /niM q ho.a.7 
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